#include<iostream>
#include<iomanip>
using namespace std;
int n;
int dis[1010];
int vis[1010];
void dfs(int step)
{
	if (step > n) {
		for (int i = 1; i <= n; i++) {
			cout << setw(5) << dis[i];
		}
		cout << endl;
		return;
	}
	for (int i = 1; i <= n; i++) {
		if (!vis[i]) {
			vis[i] = 1;
			dis[step] = i;
			dfs(step + 1);
			vis[i] = 0;
		}
	}
}
int main()
{
	cin >> n;
	dfs(1);
	return 0;
}